## Esercizio 1

Sia dato un piano cartesiano con coordinate intere, rappresentate su n bit in complemento alla radice. Una rete WWW genera (rappresentazioni di) coordinate di punti del piano secondo un algoritmo ignoto.

Sintetizzare una rete di Mealy ZZZ che prende in ingresso coppie di coordinate *X,Y* prodotte da WWW. La rete ZZZ tiene l'uscita a 0 fintanto che i punti generati da WWW rimangono nello stesso quadrante o attraversano i quadranti in senso *antiorario*, senza saltare quadranti, altrimenti porta l'uscita ad 1 per un clock e ricomincia.

Ad esempio, se WWW produce le coordinate dei punti P1-P8 della figura sottostante, nell'ordine da 1 a 8, ZZZ porta l'uscita ad 1 quando vede in ingresso le coordinate del punto P6.

Si considerino i punti sugli assi e nell'origine come appartenenti ad un quadrante qualunque (quello che fa più comodo ai fini della soluzione dell'esercizio).

Descrivere esplicitamente qualunque rete non vista a lezione.



## Esercizio 2

**Descrivere** e **sintetizzare** una Unità *XXX* che riceve una sequenza di bit da un *Circuito Generatore* e trasforma tale sequenza in una sequenza di coppie del tipo {*un bit*, *un numero naturale*} in accordo alle seguenti specifiche:

- Generatore di bit e Unità XXX pilotati dallo stesso clock;
- Numero massimo di 0 e di 1 consecutivi nella sequenza non superiore a 255;
- Primo bit ricevuto da XXX: 0
- Prima coppia emessa da XXX: {0, numero di 0 consecutivi con cui inizia la sequenza di bit};
- Seconda coppia emessa da XXX: {1, numero di 1 consecutivi che segue gli 0 di cui sopra };
  Terza coppia emessa da XXX: {0, numero di 0 consecutivi che segue gli 1 di cui sopra };
- .....



Si noti che la prima coppia deve essere emessa quando *in* viene trovato ad 1 e deve essere mantenuta per tutto il tempo in cui *in* rimane ad 1. Poi, con le stesse modalità viene emessa la seconda coppia e così via, come mostrato nel seguente esempio.



## **ATTENZIONE**

- Non ci si preoccupi se viene commesso un errore nel conteggio dei primi bit 0 dopo il reset.
- Si **tenga presente** che ad **ogni clock arriva un nuovo bit** e che quindi l'Unità *XXX* **non deve perdere il passo.**

Come verifica, si tracci un diagramma di temporizzazione in cui si evidenzi l'evoluzione dei vari registri dell'Unità *XXX*, nel caso che la sequenza di bit ricevuta sia **001100011...** (la sequenza che deve essere emessa è ovviamente **{0,2} {1,2} {0,3} {1,2}...**)